Add a Card
Issing physical card to an existing card holder.
Method: POST
{{URL}}/cardv2
Headers
Name | Value |
---|---|
Content-Type | application/json |
Payload Parameters
Parameters | Description |
---|---|
reference Optional | String Unique reference ID of the request Sample Value: "visadps100004" |
transactionType Mandatory | String Type of operation / transaction Constant Value: "ADD_CARD" |
customerId Mandatory | String Unique ID of customer who holds the card Sample Value: "100000000006001" |
accountNumber Mandatory | String Account number linked to the card Sample Value: "400320588344662" |
product Mandatory | String Name of the product associated with the card Sample Value: "DEFAULT" |
channel Mandatory | Enum Processing channel through which the card transaction happens Valid Values: PULSE VISA_DPS Sample Value: "VISA_DPS" |
program Mandatory | String Name of the program to which the card product is mapped Sample Value: "DEFAULT" |
card | Object |
cardHolderId Mandatory | String Unique id of the card holder Sample value: "CH00000000020003" |
cardType Mandatory | String Card type is physical, by default Sample Value: "PHYSICAL " |
- cURL
- C#
- Go
- NodeJs
curl --location --globoff --request GET '{{URL}}/cardv2' \
--header 'Content-Type: application/json' \
--data '{ "method": "ledger.CARD.request", "id": "1", "params": { "payload": { "reference": "visadps250001", "transactionType": "ADD_CARD", "customerId": "100000000006001", "accountNumber": "400320588344662", "product": "DEFAULT", "channel": "VISA_DPS", "program": "DEFAULT", "card": { "cardHolderId": "CH00000000020003", "cardType": "PHYSICAL" } }, "api": { "signature": "{{signature}}", "apiKey": "{{Api-key}}", "credential": "{{cred}}" } } }'
using System;
using RestSharp;
using System.Threading;
using System.Threading.Tasks;
namespace HelloWorldApplication {
class HelloWorld {
static async Task Main(string[] args) {
var options = new RestClientOptions("{{URL}}/cardv2")
{
MaxTimeout = -1,
};
var client = new RestClient(options);
var request = new RestRequest("", Method.Get);
request.AddHeader("Content-Type", "application/json");
var body = @"{
" + "\n" +
@" ""method"": ""ledger.CARD.request"",
" + "\n" +
@" ""id"": ""1"",
" + "\n" +
@" ""params"": {
" + "\n" +
@" ""payload"": {
" + "\n" +
@" ""reference"": ""visadps250001"",
" + "\n" +
@" ""transactionType"": ""ADD_CARD"",
" + "\n" +
@" ""customerId"": ""100000000006001"",
" + "\n" +
@" ""accountNumber"": ""400320588344662"",
" + "\n" +
@" ""product"": ""DEFAULT"",
" + "\n" +
@" ""channel"": ""VISA_DPS"",
" + "\n" +
@" ""program"": ""DEFAULT"",
" + "\n" +
@" ""card"": {
" + "\n" +
@" ""cardHolderId"": ""CH00000000020003"",
" + "\n" +
@" ""cardType"": ""PHYSICAL""
" + "\n" +
@" }
" + "\n" +
@" },
" + "\n" +
@" ""api"": {
" + "\n" +
@" ""signature"": ""{{signature}}"",
" + "\n" +
@" ""apiKey"": ""{{Api-key}}"",
" + "\n" +
@" ""credential"": ""{{cred}}""
" + "\n" +
@" }
" + "\n" +
@" }
" + "\n" +
@"}";
request.AddStringBody(body, DataFormat.Json);
RestResponse response = await client.ExecuteAsync(request);
Console.WriteLine(response.Content);
}
}
}
package main
import (
"fmt"
"strings"
"net/http"
"io"
)
func main() {
url := "{{URL}}/cardv2"
method := "GET"
payload := strings.NewReader(`{`+"
"+`
"method": "ledger.CARD.request",`+"
"+`
"id": "1",`+"
"+`
"params": {`+"
"+`
"payload": {`+"
"+`
"reference": "visadps250001",`+"
"+`
"transactionType": "ADD_CARD",`+"
"+`
"customerId": "100000000006001",`+"
"+`
"accountNumber": "400320588344662",`+"
"+`
"product": "DEFAULT",`+"
"+`
"channel": "VISA_DPS",`+"
"+`
"program": "DEFAULT",`+"
"+`
"card": {`+"
"+`
"cardHolderId": "CH00000000020003",`+"
"+`
"cardType": "PHYSICAL"`+"
"+`
}`+"
"+`
},`+"
"+`
"api": {`+"
"+`
"signature": "{{signature}}",`+"
"+`
"apiKey": "{{Api-key}}",`+"
"+`
"credential": "{{cred}}"`+"
"+`
}`+"
"+`
}`+"
"+`
}`)
client := &http.Client {
}
req, err := http.NewRequest(method, url, payload)
if err != nil {
fmt.Println(err)
return
}
req.Header.Add("Content-Type", "application/json")
res, err := client.Do(req)
if err != nil {
fmt.Println(err)
return
}
defer res.Body.Close()
body, err := io.ReadAll(res.Body)
if err != nil {
fmt.Println(err)
return
}
fmt.Println(string(body))
}
var https = require('follow-redirects').https;
var fs = require('fs');
var options = {
'method': 'GET',
'hostname': '{{URL}}',
'path': '/cardv2',
'headers': {
'Content-Type': 'application/json'
},
'maxRedirects': 20
};
var req = https.request(options, function (res) {
var chunks = [];
res.on("data", function (chunk) {
chunks.push(chunk);
});
res.on("end", function (chunk) {
var body = Buffer.concat(chunks);
console.log(body.toString());
});
res.on("error", function (error) {
console.error(error);
});
});
var postData = JSON.stringify({
"method": "ledger.CARD.request",
"id": "1",
"params": {
"payload": {
"reference": "visadps250001",
"transactionType": "ADD_CARD",
"customerId": "100000000006001",
"accountNumber": "400320588344662",
"product": "DEFAULT",
"channel": "VISA_DPS",
"program": "DEFAULT",
"card": {
"cardHolderId": "CH00000000020003",
"cardType": "PHYSICAL"
}
},
"api": {
"signature": "{{signature}}",
"apiKey": "{{Api-key}}",
"credential": "{{cred}}"
}
}
});
req.write(postData);
req.end();
Body
{
"method": "ledger.CARD.request",
"id": "1",
"params": {
"payload": {
"reference": "visadps250001",
"transactionType": "ADD_CARD",
"customerId": "100000000006001",
"accountNumber": "400320588344662",
"product": "DEFAULT",
"channel": "VISA_DPS",
"program": "DEFAULT",
"card": {
"cardHolderId": "CH00000000020003",
"cardType": "PHYSICAL"
}
},
"api": {
"signature": "{{signature}}",
"apiKey": "{{Api-key}}",
"credential": "{{cred}}"
}
}
}
Response: 200
Response Parameters
Parameters | Description |
---|---|
Id | String Response ID echoed from the request ID Sample Value: "1" |
result | Object |
card | Object |
cardId | String Unique ID of the card Sample Value: "6f586be7bf1c44b8b4ea11b2e2510e25" |
cardType | String Card type that has been added is physical, by default Sample Value: "PHYSICAL " |
postedDate | String Date and time when the details for adding card was posted Sample Value: "2024-11-20T06:54:26.82291052Z" |
updatedDate | String Date and time when the details for adding card was updated Sample Value: "2024-11-20T06:54:26.822910591Z" |
cardMaskNumber | String Masked representation of the card number Sample Value: "************5461" |
cardStatus | String Current status of card Sample Value: "CARD_IS_NOT_ACTIVATED" |
cardExpiryDate | String Expiration date of the card in YYYYMM format Sample Value: "202611" |
allowAtm | Boolean Allowing card for transactions through ATM Sample Value: false |
allowEcommerce | Boolean Allowing card for e-commerce transactions Sample Value: false |
allowMoto | Boolean Allowing card for transactions through mobile Sample Value: false |
allowPos | Boolean Allowing card for point-of-sale (POS) terminal transaction Sample Value: false |
allowTips | Boolean Allowing card for tips transaction Sample Value: false |
allowPurchase | Boolean Allowing card for purchase transaction Sample Value: false |
allowRefund | Boolean Allowing card for refund transaction Sample Value: false |
allowCashback | Boolean Allowing card for cashback transaction Sample Value: false |
allowWithdraw | Boolean Allowing card for ATM withdrawal transaction Sample Value: false |
allowAuthAndCompletion | Boolean Allowing for authorization and completion of transaction that happens through card Sample Value: false |
smart | Boolean Allowing card for smart transaction Sample Value: false |
checkAvsZip | Boolean Allowing card to perform AVS checks on the legalRep ZIP code during transaction Sample Value: false |
checkAvsAddr | Boolean Allowing card to perform AVS checks on the legalRep address during transaction Sample Value: false |
cvv | String Card Verification Value of the card Sample Value: "" |
transactionMade | Boolean Inicates whether any transactions can be made using the card or not Sample Value: false |
orderStatus | String Current order status of the card Sample Value: "ORDER_PLACED" |
orderId | String ID of the order placed for the card Sample Value: "4UOO1ER8E6SV000" |
isReIssue | Boolean Inicates whether the card is reissued Sample Value: false |
isReplace | Boolean Inicates whether the card is replaced Sample Value: false |
api | Object |
type | String Acknowledgement for type of operation requested for Sample Value: "ADD_CARD_ACK" |
reference | String Unique reference for the API response Sample Value: "REFvisadps100004" |
dateCreated | Number Unix timestamp of the response was created Sample Value: 1732085666 |
originalReference | String Original reference ID taken from the request Sample Value: "visadps100004" |
{
"id": "1",
"result": {
"card": {
"cardId": "0df975c5b89f46738f0cdafeeadb249a",
"cardType": "PHYSICAL",
"postedDate": "2024-11-25T06:48:42.12389341Z",
"updatedDate": "2024-11-25T06:48:42.123893668Z",
"cardMaskNumber": "************8494",
"cardStatus": "CARD_IS_NOT_ACTIVATED",
"cardExpiryDate": "202611",
"allowAtm": false,
"allowEcommerce": false,
"allowMoto": false,
"allowPos": false,
"allowTips": false,
"allowPurchase": false,
"allowRefund": false,
"allowCashback": false,
"allowWithdraw": false,
"allowAuthAndCompletion": false,
"smart": false,
"checkAvsZip": false,
"checkAvsAddr": false,
"cvv": "",
"transactionMade": false,
"orderStatus": "ORDER_PLACED",
"orderId": "4UOPKHRABW2A000",
"isReIssue": false,
"isReplace": false
},
"api": {
"type": "ADD_CARD_ACK",
"reference": "REFvisadps250001",
"dateCreated": 1732517322,
"originalReference": "visadps250001"
}
}
}